/* =========================================================
   TLAČÍTKO "DETAIL" – ZÁKLADNÍ VZHLED PRO CELÝ WEB
   ========================================================= */

.product-btn {
    display: block;
    width: 100%;
    margin-top: 10px;
}

.product-btn .btn.btn-primary {
    list-style: none;
    box-sizing: border-box;
    padding: 5px 20px;
    border-style: solid;
    border-width: 1px;
    border-radius: 25px;
    font-weight: 400;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    text-transform: none;
    white-space: normal;
    transition: all .3s ease-out;
    appearance: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    box-shadow: 0 3px 6px rgba(0,0,0,0.12);
    color: #fff;
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    width: 100%;
    max-width: 184px;
    margin: 10px auto 0;
    font-family: Roboto, sans-serif;
    font-size: 16px;
}

/* Hover efekt */
.product-btn .btn.btn-primary:hover {
    background-color: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
}

/* ---------------------------------------------------------
   Drobné narovnání v kategoriích (bez změny layoutu karty)
   – POUZE V PŘÍPADĚ, ŽE JSOU TLAČÍTKA ROZHOZENÁ
   --------------------------------------------------------- */

/* Pokud by v kategoriích bylo tlačítko nalepené, můžeme dát
   jen jednoduchý margin shora – tohle je hodně opatrné. */

/*
.products-block__item .product-btn {
    margin-top: 10px;
}
*/

/* =========================================================
   HOMEPAGE SLIDER – ZAROVNÁNÍ OBSAHU A TLAČÍTKA
   (JEN V RÁMCI .slider-group-products)
   ========================================================= */

/* Každý slide vyplní výšku, kterou mu dá Swiper */
.slider-group-products .swiper-slide {
    height: 100%;
}

/* Karta produktu ve slideru jako flex-sloupec */
.slider-group-products .swiper-slide > .product.no-code {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Blok s obrázkem a textem (.p / .p.swap-images) také jako sloupec,
   ať se umí natáhnout */
.slider-group-products .swiper-slide > .product.no-code > .p,
.slider-group-products .swiper-slide > .product.no-code > .p.swap-images {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

/* Uvnitř .p: .p-in roste, .p-bottom se posune na konec obsahu */
.slider-group-products .swiper-slide .p-in {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

.slider-group-products .swiper-slide .p-in .p-bottom {
    margin-top: auto;
}

/* Obal tlačítka – sedí pod obsahem, bez absolutního pozicování */
.slider-group-products .swiper-slide > .product.no-code > .product-btn {
    display: block;
    width: 100%;
    margin-top: 10px;  /* mezera nad tlačítkem */
}
